function
Type
control structure
Summary
Defines a custom function handler.
Syntax
[private] function <functionName> [<parametersList>]
<statementList>
end <functionName>
Description
Use the function control structure to implement a custom function.
Form. The first line of a function handler consists of the word "function" followed by the function's name. If the function has any parameters, their names come after the function name, separated by commas.
The last line of a function handler consists of the word "end" followed by the function's name.
The purpose of a function is to compute a value and return it to the handler that called the function. The function's value is returned by a return control structure within the function handler.
A function handler can contain any set of LiveCode statements. Most functions contain a return statement, which returns the value to the calling handler. This example of a custom function uses two parameters and returns a string :
function reversedName firstName,lastName
-- firstName and lastName are parameters
put lastName,firstName into constructedName
return constructedName
end reversedName
You create a custom function by writing a function handler for it. When you call the function in a handler, the function call is passed through the message path. When it reaches the object whose script contains the function handler, the statements in the handler are executed.
A custom function is called by name, just like a built-in function, as part of an expression. For example, this handler calls the custom function above:
on mouseUp
ask \"What is your first name?\"
put it into firstParam
ask \"What is your last name?\"
put it into secondParam
put reversedName(firstParam,secondParam) into field \"Name\"
end mouseUp
A function can call itself. The following example calls itself to compute the factorial of an integer:
function factorial theNumber
if theNumber = 1 then return 1
else return theNumber * factorial(theNumber -1)
end factorial
To declare a function that is local to the script it is contained in, prefix the declaration with private. For more information about this see the dictionary entry for the private keyword.
Parameters
Name | Type | Description |
---|---|---|
functionName | string | A string up to 65,535 characters in length. |
parametersList | The parametersList consists of one or more parameter names, separated by commas. | |
statementList | The statementList consists of one or more LiveCode statements. The final statement is typically a return statement, which sends the value derived in the function handler back to the statement that calls the function. |
Examples
function myFunction
return "test"
end myFunction
function cubeIt pNum
return pNum * pNum * pNum
end cubeIt
Related
function: functionNames, param, paramCount, result
glossary: call, caller, control structure, execute, expression, handler, message path, parameter, return, statement
keyword: dollar, end, private, string
control structure: exit, return
Compatibility and Support
Introduced
LiveCode 1.0
OS
mac
windows
linux
ios
android
web
Platforms
desktop
server
mobile